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BACKGROUND 



1. Field 

This invention relates to the field of data security. In particular, the invention 
relates to a platform and method for certifying a key within protected hardware, 
5 2, Background 

Advances in technology have opened up many opportunities for appUcations that 
go beyond the traditional ways of doing business. Electronic commerce (e-commerce) 
and business-to-business (B2B) transactions are now becoming popular, reaching the 
global markets at a fast rate. Unfortunately, while electronic platforms like computers 
10 provide users with convenient and efficient methods of doing business, communicating 
and transacting, they are also vulnerable for unscrupulous attacks. Examples of these 
attacks include virus, intrusion, security breach, and tampering, to name a few. 
Therefore, it is becoming more and more important to protect the integrity of data stored 
within or downloaded into a platform. 

15 Various data security mechanisms may be used to protect the integrity of data 

exchanged between electronic platforms. One type of data security mechanism involves 
the development of cryptographic hardware having a private key stored in a secure 
manner. This hardware produces a digital signature by digitally signing data with the 
pre-stored private key in accordance with a selected digital signature fimction (e.g., 

20 Digital Signature Algorithm "DSA"). Accompanying the data during transmission, the 
digital signature protects the integrity of the data. 

In order to recover the data, an authentication certificate normally accompanies 
the digital signature. The authentication certificate provides a public key corresponding 
to the private key for use in data recovery and for certifying (or attesting) to something. 
25 The meaning of a certificate depends on the contents of the certificate and the 
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empowerment of the certificate signer (issuer). For example, the attestation may indicate 
that a given signature private key was installed in protected hardware, especially an 
isolated execution architecture designed below. 
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RRTRF DESCRTPTTON OF THR DRAWINGS 



The features and advantages of the present invention will become apparent from 
the following detailed description of the present invention in which: 

Figure 1 A is a diagram illustrating an embodiment of the logical operating 
5 architecture for the ISOX™ architecture of the platform. 

Figure IB is an illustrative diagram showing the accessibility of various elements 
in the operating system and the processor according to one embodiment of the invention, 

Figure IC is a block diagram of an illustrative embodiment of a platform utilizing 
the present invention. 

10 Figure 2 is a block diagram of an illustrative embodiment of the communications 

between the platform of Figure IC and a remotely located platform. 

Figure 3 is a block diagram of a first illustrative embodiment of the certification 
technique for the attestation key. 

Figure 4 is a block diagram of a second illustrative embodiment of the 
15 certification technique for the attestation key. 

Figure 5 is a block diagram of a third illustrative embodiment of the certification 
technique for the attestation key. 
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DKTATT.FD DESCRIPTION 

The present invention relates to a platform and method for certifying a key within 
protected hardware. Herein, certain details are set forth in order to provide a thorough 
understanding of the present invention. It is apparent to a person of ordinary skill in the 
art, however, that the present invention may be practiced through many embodiments 
other that those illustrated. Well-known circuits and hashing techniques are not set forth 
in detail in order to avoid unnecessarily obscuring the present invention. 

In the following description, terminology is used to discuss certain features of the 
present invention. For example, a "platform" includes hardware equipment and/or 
software that perform different fimctions on stored information. Examples of a platform 
include, but are not hmited or restricted to a computer (e.g., desktop, a laptop, a hand- 
held, a server, a workstation, etc.), desktop office equipment (e.g., printer, scanner, a 
facsimile machine, etc.), a wireless telephone handset, a television set-top box, and the 
hke. A "software module" includes code that, when executed, performs a certain 
function. A "nub" is a series of code instructions, possibly a subset of code from a 
software module. A "hnk" is broadly defined as one or more information-carrying 
mediums (e.g., electrical wire, optical fiber, cable, bus, or wireless signaUng technology). 

In addition, the term "information" is defined as one or more bits of data, address, 
and/or control. A "segment" is one or more bytes of information. A "page" is a 
predetermined number of bytes, usually a power of two in length (e.g., 512, 1024, etc.). 
A "one-way hash function" is a function, mathematical or otherwise, that converts 
information from a variable-length to a fixed-length (referred to as a "hash value" or 
"digest"). The term "one-way" indicates that there does not readily exist an inverse 
fiinction to recover any discernible portion of the original information from the fixed- 
length hash value. Examples of a hash fimction include MD5 provided by RSA Data 
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Security of Redwood City, California, or Secure Hash Algorithm (SHA-1) as specified a 
1995 publication Secure Hash Standard FIPS 180-1 entitled "Federal Information 
Processing Standards Publication" (April 17, 1995). 

1. Architecture Overview 

A. Isolated Execution Platform 

One principle for enhancing security of transmitted is through configuration of the 
platform with an isolated execution (ISOX™) architecture. The ISOX™ architecture 
includes logical and physical definitions of hardware and software components that interact 
directly or indirectly with an operating system of a platform. Herein, the operating system 
and a processor of the platform may have several levels of hierarchy, referred to as rings, 
which correspond to various operational modes. A "ring" is a logical division of hardware 
and software components that are designed to perform dedicated tasks within the operating 
system. The division is typically based on the degree or level of privilege, namely the 
ability to make changes to the platform. For example, a ring-0 is the innermost ring, being 
at the highest level of the hierarchy. Ring-0 encompasses the most critical, privileged 
components. Ring-3 is the outermost ring, being at the lowest level of the hierarchy. Ring- 
3 typically encompasses user level appHcations, which are normally given the lowest level 
of privilege. Ring-1 and ring-2 represent the intermediate rings with decreasing levels of 
privilege. 

Figure lA is a diagram illustrating an embodiment of a logical operating 
architecture 50 of the ISOX^m architecture. The logical operating architecture 50 is an 
abstraction of the components of an operatuag system and the processor. The logical 
operating architecture 50 includes ring-0 10, ring-1 20, ring-2 30, ring-3 40, and a 
processor nub loader 52. The logical operating architecture 50 has at least two modes of 
operation: normal execution mode and isolated execution mode. Each ring in the logical 
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operating architecture 50 can operate in both modes. The processor nub loader 52 
operates only in the isolated execution mode. 

Ring-0 10 includes two portions: a normal execution Ring-O 11 and an isolated 
execution Ring-O 15. The normal execution Ring-O 1 1 includes software modules that 

5 are critical for the operating system. Typically, these software modules include a primary 
operating system 12 referred to as the "kemel"(e.g., the unprotected segments of the 
operating system), software drivers 13, and hardware drivers 14. The isolated execution 
Ring-O 15 includes an operating system (OS) nub 16 and a processor nub 18 as described 
below. The OS nub 16 and the processor nub 18 are instances of an OS executive (OSE) 

10 and processor executive (PE), respectively. The OSE and the PE are part of executive 
entities that operate in a secure environment associated with the isolated area 70 and the 
isolated execution mode. The processor nub loader 52 is a protected bootstrap loader 
code held within the chipset itself and is responsible for loading the processor nub 18 
from the processor or chipset into a region of protected memory as fiirther described 

15 below. 

Similarly, ring-1 20, ring-2 30, and ring-3 40 include normal execution ring-1 21, 
ring-2 31, ring-3 41, and isolated execution ring-1 25, ring-2 35, and ring-3 45, 
respectively. In particular, normal execution ring-3 includes N applications 42i-42n and 
isolated execution ring-3 includes M applets 46,-46^ (where "N" and "M" are positive 
20 whole numbers). 

One concept of the isolated execution architecture is the creation of a region in 
system memory protected by the processor and /or chipset m the platform. This region of 
protected memory is referred to as an "isolated area". Access to the isolated area is 
permitted using special memory read and write cycles, which are referred to as "isolated 
25 read and write" cycles. The isolated read and write cycles are issued by the processor 
operating in the isolated execution mode. 
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The processor nub loader 52 verifies and loads a ring-0 nub software module (e.g., 
processor nub 18) into the isolated area. The processor nub 18 provides the basic 
hardware-related services to support isolated execution. For example, one task of the 
processor nub 18 is to verify and load the ring-0 OS nub 16 into the isolated area 70 as 
5 shown in Figure IB. 

The OS nub 16 provides links to services in the primary operating system 12, 
provides page management within the isolated area, and has the responsibility for loading 
some ring-O software modules as well as ring-3 software modules 45 (e.g., applets 46^- 
46m) into protected pages allocated in the isolated area. The OS nub 16 may also support 
10 encrypting and hashing the isolated area pages before evicting the page(s) to the ordinary 
(unprotected) memory, and/or checking the page contents upon restoration of the page. 

Figure IB is an illustrative diagram showing the accessibility of various elements 
in the operating system 10 and the processor according to one embodiment of the 
invention. For clarity sake, only elements of ring-0 10 and ring-3 40 are shown. The 
15 various elements in the logical operating architecture 50 access an accessible physical 
memory 60 according to their ring hierarchy and the execution mode. 

The accessible physical memory 60 includes an isolated area 70 and a non- 
isolated area 80. The isolated area 70 includes applet pages 72 and nub pages 74. The 
non-isolated area 80 includes application pages 82 and operating system (OS) pages 84. 
20 The isolated area 70 is accessible only to elements of the operating system and processor 
operating in isolated execution mode. The non-isolated area 80 is accessible to all 
elements of the ring-0 operating system and processor. 

The normal execution ring-0 1 1 includmg the primary OS 12, the software drivers 
13, and the hardware drivers 14, can access both the OS pages 84 and the application 
25 pages 82. The normal execution ring-3, including apphcations 421-42^, can access only 
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to the application pages 82. Both the normal execution ring-0 1 1 and ring-3 41, however, 
cannot access the isolated area 70. 

The isolated execution ring-0 15, including the OS nub 16 and the processor nub 
18, can access both the isolated area 70 (including the applet pages 72 and the nub pages 
5 74) and the non-isolated area 80 (including the appUcation pages 82 and the OS pages 
84). The isolated execution ring-3 45, including applets 46j-46m, can access only the 
apphcation pages 82 and the applet pages 72. The applets 46^-46^^ reside in the isolated 
area 70. 

Referring to Figure IC, a first block diagram of an illustrative embodiment of a 
10 platform utilizing the present invention is shown. The platform 100 comprises a 
processor 1 10, a system memory 140 and an input/output control hub (ICH) 150 in 
communication with each other. In this embodiment, however, the platform 100 further 
includes a memory control hub (MCH) 130 and a non-volatile memory (e.g., flash) 160 
coupled to the ICH 150. The MCH 130 is further coupled to the processor 1 10 via a host 
15 bus 120. The ICH 1 50 may be integrated into a chipset together with or separate from the 
MCH 130. 

It is contemplated that the platform 100 may be in communication with peripheral 
components such as a mass storage device 170, one or more input/output (I/O) devices 
175, and a token 180 via a token bus 185 and/or a token reader 190. For clarity, the 
20 specific links for these peripheral components (e.g., Peripheral Component Interconnect 
"PCI", accelerated graphics port "AGP", Industry Standard Architecture "ISA", 
Universal Serial Bus "USB", etc.) are not shown. 

The processor 110 represents a central processing unit of any type of architecture, 
such as complex instruction set computers (CISC), reduced instruction set computers 
25 (RISC), very long instruction word (VLIW), or hybrid architecture. In one embodiment, 
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the processor 1 10 is compatible with the Intel Architecture (lA) processor, such as the lA- 
32 and the IA-64. The processor 110 includes an isolated execution circuit 115. The 
isolated execution circuit 115 provides a mechanism to allow the processor 110 to operate 
in an isolated execution mode. The isolated execution circuit 115 provides hardware and 
5 software support for the isolated execution mode. This support includes configuration for 
isolated execution, definition of the isolated area, definition (e.g., decoding and 
execution) of isolated instructions, generation of isolated access bus cycles, and 
generation of isolated mode interrupts. 

The host bus 120 provides interface signals to allow the processor 1 10 to 
10 communicate with other processors or devices, e.g., the MCH 130. In addition to normal 
mode, the host bus 120 supports an isolated access bus mode with corresponding 
interface signals for isolated read and write cycles when the processor 1 10 is configured 
in the isolated execution mode. The isolated access bus mode is asserted on memory 
accesses initiated while the processor 1 10 is in the isolated execution mode if the physical 
15 address falls within the isolated area address range. The isolated access bus mode is also 
asserted on instruction pre-fetch and cache write-back cycles if the address is within the 
isolated area address range. The processor 110 responds to snoop cycles to a cached 
address within the isolated area address range if the isolated access bus cycle is asserted. 

The MCH 130 provides control and configuration of memory and input/output 
20 devices such as the system memory 140 and the ICH 150. The MCH 130 provides 

interface circuits to recognize and service isolated access assertions on memory reference 
bus cycles, including isolated memory read and write cycles. In addition, the MCH 130 
has memory range registers (e.g., base and length registers) to represent the isolated area 
in the system memory 140. Once configured, the MCH 130 aborts any access to the 
25 isolated area when the isolated access bus mode is not asserted. 
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The system memory 140 stores code and data. The system memory 140 is 
typically implemented with dynamic random access memory (DRAM) or static random 
access memory (SRAM). The system memory 140 includes the accessible physical 
memory 60 (shown in Figure IB). The accessible physical memory includes a loaded 
5 operating system (OS) 142, the isolated area 70 (shown in Figure IB), and an isolated 
control and status space 148. The loaded OS 142 is the portion of the operating system 
that is loaded into the system memory 140. The loaded OS 142 is typically loaded from 
mass storage device 170 via some boot code in a boot storage such as a boot read only 
memory (ROM). 

10 As shown in Figures IB and IC, the isolated area 70 is the memory area that is 

defined by the processor 110 when operating in the isolated execution mode. Access to 
the isolated area 70 is restricted and is enforced by the processor 110 and/or the MCH 
130 or other chipset that integrates the isolated area functionalities. 

Referring back to Figure IC, the isolated control and status space 148 is an 
15 input/output (I/0)-hke, independent address space defined by the processor 1 10 and/or 
the MCH 130. The isolated control and status space 148 contains (i) isolated execution 
control and status registers, and (ii) related initialization code invoked directly by the 
isolated instructions executed by the processor 110. The isolated control and status space 
148 does not overlap any existing address space and is accessed using the isolated bus 
20 cycles. The system memory 140 may also include other programs or data that are not 
shown herein. 

As shown in Figure IC, the ICH 150 has a number of functionalities that are 
designed to support isolated execution in addition to the traditional I/O fimctions. In this 
embodiment J the ICH 150 comprises at least the processor nub loader 52 (shown in 
25 Figure lA), a hardware-protected memory 152, a cryptographic key storage 154 and a 
token bus interface 158 to provide a signaling interface with the token bus 185. For 
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clarity, only one ICH 150 is shown although platform 100 may be implemented with 
multiple ICHs. When there are multiple ICHs, a designated ICH is selected to control the 
isolated area configuration and status. This selection may be performed by an external 
strapping pin. As is known by one skilled in the art, other methods of selecting can be 
5 used. 

The processor nub loader 52, as shown in Figures 1 A and IC, includes a processor 
nub loader code and its hash value (or digest). After being invoked by execution of an 
appropriated isolated instruction (e.g., ISO-INIT) by the processor 1 10, the processor nub 
loader 52 is transferred to the isolated area 70. Thereafter, the processor nub loader 52 

10 copies the processor nub 18 from the non-volatile memory 160 into the isolated area 70, 
verifies and places the hash value of the processor nub 18 into an audit log of the 
hardware-protected memory 152 as described below. In one embodiment, the hardware- 
protected memory 152 is implemented as any memory array with single write, multiple 
read capability. This non-modifiable capability is controlled by logic or is part of the 

15 inherent nature of the memory itself. For example, as shown, the protected memory 152 
may include a pluraHty of single write, multiple read registers. 

As shown in Figures IC, in one embodiment, the protected memory 152 includes 
an audit log 156, The "audit log" 156 is a listing of data that represents what information 
has been successfially loaded into the system memory 140 after power-on of the platform 

20 100, For example, the representative data may be hash values of software modules 

loaded into the system memory 140. These software modules may include the processor 
nub 18, the OS nub 16, and/or any other critical software modules (e.g., ring-0 modules) 
loaded into the isolated area 70. Thus, the audit log 156 can act as a fingerprint that 
identifies information loaded into the platform (e.g., the ring-0 code controlling the 

25 isolated execution configuration and operation), and is used to attest or prove the state of 
the current isolated execution. 
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Of course, it is contemplated that the audit log 156 may be stored collectively in 
the protected memory 152 and unprotected memory (e.g., a memory array in the non- 
isolated area 80 of the system memory 140 of Figure IB). For that case, a pointer to the 
beginning of a memory array in the unprotected memory is stored in the protected 
5 memory 152. In addition, the length of the audit log 156 and a total hash value of the 
contents of the audit log 156 are stored with the pointer as well. 

The protected memory 152 further contains a predetermined address space 
reserved so that any read or write to the predetermined address space is passed to the 
token 180. For example, one portion of address space may include a register containing 
10 an address of an attestation key. 

The cryptographic key storage 154 holds a symmetric key that is unique for the 
platform 100. In one embodiment, the cryptographic key storage 154 includes internal 
fuses that are programmed at manufacturing. Alternatively, the symmetric key contained 
in the cryptographic key storage 154 may create the aid of a random number generator. 

15 Referring still to Figure IC, the non- volatile memory 160 stores non- volatile 

information. Typically, the non- volatile memory 160 is implemented in flash memory. 
The non- volatile memory 160 includes the processor nub 18 and a binding key storage 
1 64. The processor nub 1 8 provides the initial set-up and low-level management of the 
isolated area 70 of the system memory 140, including verification, loading, and logging 

20 of the OS nub 16, and the management of the symmetric key used to protect the operating 
system nub's secrets. The processor nub 18 may also provide application programming 
interface (API) abstractions to low-level security services provided by other hardware. 
The processor nub 18 may also be distributed by the original equipment manufacturer 
(OEM) or operating system vendor (OS V) via a boot disk. 
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The mass storage device 170 stores archive information such as code (e.g., 
processor nub 18), programs, files, data, applications (e.g., apphcations 42^-42^% applets 
(e.g., applets 46^ to 46^) and operating systems. The mass storage device 170 may also 
include platform readable medium such as a compact disk (CD) ROM 172 or a hard drive 
5 176 as shown. Other types of "platform readable medium" include magnetic, optical or 
electrical medium such as a flash memory, an erasable ROM (EROM), a floppy diskette, 
an optical disk, and the like. 

I/O devices 175 may include any I/O devices to perform I/O functions. Examples 
of I/O devices 175 include controller for input devices (e.g., keyboard, mouse, trackball, 
10 pointing device), media card (e.g., audio, video, graphics), conraiunication card (e.g., 
network, modem, etc.) to estabUsh a link with a remotely located platform, or any other 
peripheral controllers. 

The token bus 185 provides an interface between the ICH 150 and one or more 
tokens 180 in the system. A "token" 180 is a device that performs dedicated I/O 
15 functions with security. The token 1 80 may be stationary (e.g., a motherboard token) or 
portable to be coupled via the token reader 190 as shown. The token bus interface 158 in 
the ICH 150 couples the token bus 180 to the ICH 150 and ensures that when 
commanded to prove the state of the isolated execution, the corresponding token 180 
signs only valid isolated hash values, 

20 B. Self-Generation and Communications 

Referring to Figure 2, in one embodiment, an attestation key pair 200 is generated 
within the platform 100. A private attestation key (PRK) 210 of the attestation key pair 
200 is stored in non-volatile memory protected by hardware. This non-volatile memory 
215 may be part of the system memory 140 of Figure 1 or memory employed within the 
25 chipset such as the ICH 150 for example. It is contemplated, however, that a pubUc 
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attestation key 220 of the attestation key pair 200 is placed in non- volatile memory freely 
accessible by the software executed by the processor 1 10 or tokens 180 coupled to the 
token bus 185. 

Upon receiving a challenge message 240 from a remotely located platform 250, 
5 the platform 100 generates a response message 260. Accompanied by a copy of the audit 
log 156, the response message 260 includes a random nonce 270 recovered from the 
challenge message 240 and a hash value 280 of the audit log. Since the hash value 280 
may be modified during transit, software running in the isolated area 70 (see Fig. IC) 
signs the random nonce 270 and hash value 280 with the private attestation key 210, 
10 Although not shown, the response message 260 may further include the audit log 1 56 and 
a certificate 290 including the public attestation key 220 and attesting that the private 
attestation key 210 was installed in hardware-protected memory. The audit log 156 and 
the certificate 290 would not need to be written into the signed portion of the message 
260. 

15 11. Certification Techniques for the Self-Generated At testation Kev 

A. User Certification 

Referring now to Figiure 3, an illustrative flowchart of a first embodiment of the 
operations of the platform to certify a self-generated private attestation key loaded in 
protected memory is shown. During its first initial boot cycle that is normally trustable, 
20 the platform generates the attestation key pair, namely the pubUc attestation key and its 
corresponding private attestation key (block 300). Herein, the attestation key pair may be 
generated by (i) a random or pseudo-random number generator possibly situated in the 
ICH, (ii) a token separate from the platform and coupled to the token bus and the like. 

The user is presented with the pubhc attestation key while the private attestation 
25 key is securely stored in memory, in one situation, by the private attestation key being 
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stored in non-volatile memory within the platform (e.g., ICH). (blocks 310 and 320). 
Other situations include encrypting the private attestation key with a previously stored 
symmetric key. Examples for presentation of the public attestation key includes visually 
displaying the bits or characters forming the public attestation key or downloading the 
5 public attestation key to a platform readable medium for distribution to an entity having 
control of the remotely located platform for example. Thus, in certain relationships 
between the user and the entity (e.g., where the entity is configured to protect the user's 
data), the generation of the attestation key pair and providing of the public attestation key 
to the entity constitutes sufficient certification. That is, if the user is a reUable authority 
10 based on the perception of a certificate verifier (e.g., the entity), then the user can simply 
generate an attestation certificate. In this embodiment, the attestation certificate is 
information digitally signed by the private attestation key. Alternatively, the user can 
provide evidence to another entity to issue the attestation certificate. 

B. Certification by an Agent for an Outside Entity 

15 Referring now to Figure 4, an illustrative flowchart of a second embodiment of 

the operations of the platform to certify a self-generated attestation key is shown. For 
example, upon installation, upgrade or repair of the platform, an agent for an entity 
controlling a remotely located platform installs a platform readable medium (e.g., a token, 
CD-ROM, etc.) and boots the platform with code approved by the entity stored on the 

20 readable medium (blocks 400 and 410). The agent may now execute an applet running 
within the isolated area of the system memory to generate the attestation key pair (block 
420). 

In particular, a public attestation key of the attestation key pair is provided to an 
application supphed by the readable medium in order to produce an attestation certificate. 
25 The certificate generally includes the pubUc attestation key encrypted with a private key 
of the entity represented by the agent (blocks 430 and 440). The public key and the 
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certificate are placed in the protected memory for subsequent transmission to a remote 
platform when verifying the security of the platform (block 450). That is, when the user 
is not an acceptable authority on the state of the platform to some verifier, some agent for 
that verifier can inspect the platform and issue the attestation certificate. 

5 C. Original Equipment Manufacturer 

Referring to Figure 5, an illustrative flowchart of a third embodiment of the 
operations of the platform to certify a self-generated attestation key is shown. As set 
forth in block 500, the public attestation key is generated during assembly of the platform 
by the original equipment manufacturer (OEM), The OEM signs the certificate including 

10 the public attestation key to certify that its corresponding private key is securely stored in 
protected memory (e.g., either cryptographically secure or stored in hardware protected 
memory such as memory 152 of Figure IC or in the isolated area 70) and that the 
protected memory has not been tampered with (blocks 510 and 520). This case is similar 
as described above, in that some agent other than the user is responsible for issuing the 

15 attestation certificate, but this case will have different cost and risk parameters. 

In all three cases or any others like these, the choice of issuer of an attestation 
certificate depends on criteria of any entity that will verify the certificate. That choice is 
based on the verifier's own preexisting relationships with the various possible attesters: 
the platform owner, an agent who goes to the platform in question, the OEM who built 
20 the platform, etc. A single platform might have to satisfy multiple different verifiers and 
might therefore hold multiple attestation certificates, over one or more attestation keys. 

While this invention has been described with reference to illustrative 
embodiments, this description is not intended to be construed in a limiting sense. Various 
modifications of the illustrative embodiments, as well as other embodiments of the 
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invention, which are apparent to persons skilled in the art to which the invention pertains 
are deemed to he within the spirit and scope of the invention. 
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CLAIMS 



What is claimed is: 



1 LA method comprising: 

2 generating an attestation key pair within a platform; and 

3 producing a certificate including a public attestation key to attest that a private 

4 attestation key, corresponding to the public attestation key, is stored in hardware- 

5 protected memory. 

1 2. The method of claim 1 , wherein prior to generating the attestation key 

2 pair, the method further comprises providing the platform including a processor and a 

3 system memory including an isolated area accessible only by the processor running in an 

4 isolated execution mode. 

1 3 . The method of claim 1 , wherein the producing of the certificate occurs at 

2 an initial power-on of the platform. 

1 4. The method of claim 2, wherein the producing of the certificate comprises: 

2 booting the platform from code stored in a platform readable medium loaded by 

3 an agent; and 

4 executing an applet running within the isolated area of the system memory to 

5 generate the attestation key pair. 

1 5 . The method of claim 4, wherein the producing of the certificate further 

2 comprises encrypting the pubUc attestation key with a private key held by the agent. 



042390.P8097 



18 



Patent Application 
Express Mail No. EW66333747US 



1 6 The method of claim 1, wherein the producing of the certificate comprises: 

2 encrypting the pubhc attestation key using a private key held by an original 

3 equipment manufacturer of the platform. 

1 7 The method of claim 1 further comprising: 

2 receiving a challenge message from a remotely located platform, the challenge 

3 message including a nonce. 

1 8 The method of claim 7 further comprising: 

2 generating a response message for transmission to the remotely located platform, 

3 the response message including the certificate, the nonce and a hash value of an audit log. 

1 9 The method of claim 8, wherein the nonce and the hash value are signed 

2 with the private attestation key. 

1 1 0. A platform comprising: 

2 a processor to operate in one of a normal execution mode and an isolated 

3 execution mode; 

4 an input/output control hub in communication with the processor, the input/output 

5 control hub to generate an attestation key pair and to store an audit log being a hsting of 

6 data representing a plurahty of software modules loaded within the platform. 

1 11 The platform of claim 1 0, wherein the plurality of software modules 

2 include a processor nub and an operating system nub. 
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1 1 2. The platform of claim 1 0 further comprising at least one input/output 

2 device allowing communications with a remotely located platform. 



1 1 3 . The platform of claim 1 0 further comprising a token link coupled to the 

2 input/output control hub, the token link providing a communication path for a token. 

1 14. The platform of claim 13 wherein the token stores a private attestation key 

2 of the attestation key pair. 

1 1 5 . A platform comprising : 

2 a processor to operate in either a normal execution mode or an isolated execution 

3 mode; 

4 a system memory coupled to the processor, the system memory including an 

5 isolated area and a non-isolated area; 

6 a device in conmiunication with the processor, the device to store an audit log, the 

7 audit log being a listing of data or presenting information loaded into the isolated area of 

8 the system memory; and 

9 a token to generate an attestation key pair to load at least a private attestation key 
10 of the attestation key pair into a protected memory. 

1 1 6. The platform of claim 1 5, wherein the protected memory includes a 

2 plurality of single write, multiple-read control registers. 

1 17. The platform of claim 15, wherein the device is an input/output control 

2 nub. 
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1 

2 
3 



1 8. The platforai of claim 15, wherein the token further generates an 
attestation certificate to attest that the private attestation key is stored in protected 
memory. 



1 19. A method comprising: 

2 generating an attestation key pair; 

3 storing a private attestation key into hardware-protected memory; and 

4 producing a certificate including the public attestation key to attest that the private 

5 attestation key is stored in the hardware protected memory. 



1 



20. The method of claim 19, wherein the hardware-protected memory includes 



2 single-write, multiple-read control registers. 

1 21 . The method of claim 19, wherein the hardware-protected memory includes 

2 an isolated area of a system memory accessible to a processor when operating in an 

3 isolated execution mode. 

1 22. The method of claim 1 9, wherein the producing of the certificate occurs at 

2 an initial power-on of the platform. 

1 23. The method of claim 19, wherein the producing of the certificate 

2 comprises: 

3 booting a platform including the hardware-protected memory from code stored in 

4 a readable medium loaded by an agent; and 

5 executing an applet stored in the hardware-protected memory to generate the 

6 attestation key pair. 
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ABSTRACT 



In one embodiment, a method for certifying an attestation key comprises 
generating a remote attestation key pair within a platform and producing a certificate. 
The certificate includes a public attestation key to attest that a private attestation key, 
corresponding to the public attestation key, is stored in hardware-protected memory. 



03/31/2000 16:06 661-254-8096 MARY J. HILL & ASSOC PAGE 02/02 




03/30/2008 11:15 



661-254-8096 



MARY J. HILL ASSOC 



PAGE 0i 




03/-30/2000 11:15 661-254-809B 



MARY J. HILL S ASSOC 



PAGE 04 








9608-fS3-T99 z;t?:zT 000z;/e:z;/ 



03/^0/2000 11:15 661-254-8096 



MARY J. HILL & ASSOC 



PAGE 05 



FIG. 3 



START 



GENERATE ATTESTATION KEY 
PAIR WITHIN PLATFORM 



USER PRESENTED WITH 
PUBUC ATTESTATION KEY 



PRNATE ATTESTATION KEY 
SECURELY STORED IN MEMORY 



300 




END 



310 



320 



FIG. 5 



START 



500 



OEM GENERATES THE ATTESTATION KEY PAIR 
WITHIN THE PLATFORM DURING ASSEMBLY 



510 



PRIVATE ATTESTATION KEY SECURELY 
STORED IN MEMORY WITHIN PLA TFORM 



520 



OEM PRODUCES A CERTIFICATE INCLUDING 
THE PUBUC ATTESTATION KEY USING 
THE OEM'S PRIVATE KEY 



03/^0/2000 11:15 651-254-8096 



MARY J. HILL & ASSOC 



400 



AGENT INSTALLS READABLE 
MEDIUM INTO PLATFORM 



BOOT PLATFORM BASED ON CODE 
STORED IN THE READABLE MEDIUM 



I 



STORE THEPUBUCATTESTAVONKEY 
AND THE CERTIFICATE IN MEMORY 



SECURELY STORE THE PRIVATE 
A TTESTA TION KEY IN MEMORY 




END 



410 



420 



EXECUTE APPLET RUNNING IN THE 
ISOLATED AREA TO GENERATE 
THE ATTESTATION KEY PAIR 



430 



PRODUCE CERTIHCA TE CONTAINING 
THE PUBUC ATTESTATION KEY USING 
THE PRIVA TE KEY CONTROLED BY AGENT 



440 



450 



FIG 4 



Attorney's Docket No.: 042390.P8Q97 



DECLARATION AND POWER OF ATTORNEY FOR PATENT APPLICATION 
(FOR INTEL CORPORATION PATENT APPLICATIONS) 

As a below named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below, next to my name, 

I beheve I am the original, fnst, and sole inventor (if only one name is listed below) or an original, first, and joint inventor 
(if plural names are listed below) of the subject matter which is claimed and for which a patent is sought on the invention 
entitled 

PLATFORM AND METHOD FOR ISSUING AND CERTIFYING A 
HARDWARE-PROTECTED ATTESTATION KEY 

the specification of which 

is attached hereto. 

was filed on „ as — 

United States Application Number 

or PCX International Apphcation Number 

and was amended on „_ • 

(if apphcable) 

I hereby state that I have reviewed and understand the contents of the above-identified specification, including the claim(s), 
as amended by any amendment referred to above. I do not know and do not believe that the claimed invention was ever 
known or used in the United States of America before my invention thereof, or patented or described in any printed 
publication in any country before my invention thereof or more than one year prior to this application, that the same was 
not in public use or on sale in the United States of America more than one year prior to this application, and that the 
invention has not been patented or made the subject of an inventor's certificate issued before the date of this application in 
any country foreign to the United States of America on an application filed by me or my legal representatives or assigns 
more than twelve months (for a utility patent application) or six months (for a design patent application) prior to this 
application. 

I acknowledge the duty to disclose all information known to me to be material to patentability as defmed in Title 37, Code 
of Federal Regulations, Section 1.56. 

I hereby claim foreign priority benefits under Title 35, United States Code, Section 1 19(a)-(d), of any foreign 
application(s) for patent or inventor's certificate listed below and have also identified below any foreign application for 
patent or inventor's certificate having a filing date before that of the application on which priority is claimed: 

Prior Foreign ApplicationfsV 



APPLICATION 
NUMBER 


COUNTRY (OR 
INDICATE IF PCT) 


DATE OF FILING 
(day, month, year) 


PRIORITY CLAIMED 
UNDER 37 use 119 








□ No □ Yes 








□ No [jYqs 








□ No qYcs 



I hereby claim the benefit under Title 35, United States Code, Section 1 19(e) of any United States 
provisional application(s) listed below: 



APPLICATION 
NUMBER 


FILING DATE 












1 



Docket No. 042390.P8097 



I hereby claim the benefit under Title 35, United States Code, Section 120 of any United States application(s) listed below 
and insofar as the subject matter of each of the claims of this application is not disclosed in the prior United States 
application in the manner provided by the fnst paragraph of Title 35, United States Code, Section 112,1 acknowledge the 
duty to disclose all information known to me to be material to patentability as defmed in Title 37, Code of Federal 
Regulations, Section 1.56 which became available between the filing date of the prior application and the national or PCT 
international filing date of this application: 



APPLICATION 
NUMBER 


FILING DATE 


STAIUS (ISSUED, 
PENDING, ABANDONED) 





















I hereby appoint the persons Usted on Appendix A hereto (which is incorporated by reference and a part of this document) 
as my respective patent attorneys and patent agents, with full power of substitution and revocation, to prosecute this 
application and to transact all business in the Patent and Trademark Office connected herewith. 



Send correspondence to: 

William W. Schaal, Reg, No. 39,018, BLAKELY, SOKOLOFF, TAYLOR & ZAFMAN, LLP 
(Name of Attorney or Agent) 

12400 Wilshne Boulevard, 7th Floor, Los Angeles, California 90025 and direct telephone calls to: 
William W. SchaaL (714) 557-3800. 
(Name of Attorney or Agent) 

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information 
and belief are believed to be true; and further that these statements were made with the knowledge that willful false 
statements and the like so made are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the 
United States Code and that such willful false statements may jeopardize the validity of the application or any patent issued 
thereon. 



Full Name of Sole/First Inventor (given name, family name) Carl M. Ellison 



Inventor's Signature Date 



Residence Portland, Oregon USA Citizenship USA 



(City,Stat^ (Country) 



P.O. Address 181 NW 28th Avenue 



Portland, Oregon 97210-2214 USA 



INTEL CORPORATION 2 Docket No 042390 P8097 

Rev. 09/09/99 (D3 INTEL) ^ uocKex iNO. U4z:>yu.rouy / 



Full Name of Second/ Joint Inventor (given name, family name) Roger A. GoUiver 



Inventor's Signature Date 



Residence Beaverton, Oregon USA Citizenship USA 

(€tty-rSnm) (Country)^ 

P. 0. Address 13340 SW Violet Court 

Beaverton, Oregon 97008-5014 USA 



Full Name of Third/ Joint Inventor (given name, family name) Howard C. Herbert 

Inventor's Signature Date 

Residence Phoenix, Arizona USA Citizenship USA 

(City , State) (Country) 

P. O. Address 16817 South 1st Drive 

Phoenix, Arizona 85045 USA 



Full Name of Fourth/Joint Inventor (given name, family name) Derrick C. Lin 



Inventor's Signature Date 



Residence Foster City, Cahfomia USA Citizenship USA 

tCity, Stats) (Cuuntry)- 

P. O. Address 113 Barkentine Street 

Foster City, Cahfomia 94404 USA 



Full Name of Fifth/ Joint Inventor (given name, family name) 

Inventor's Signature 



Francis X. McKeen 



Residence Portland, Oregon USA 



JCiiyTState) 

P.O. Address 10612 NW LeMans Court 



Date 



Citizenship USA 



~[Uduntry)~ 



Portland, Oregon 97229 USA 



EVTEL CORPORATION 

Rev. 09/09/99 (D3 INTEL) 



Docket No. 042390.P8097 



Full Name of Sixth/Joint Inventor (given name, family name) Gil Neiger 



Inventor' s Signature Date 

Residence Portand, Oregon USA Citizenship USA 



TO^TW {Country) 



P. O. Address 2424 NE 1 1th Avenue 



Portand, Oregon 97212 USA 



Full Name of Seventh/ Joint Inventor (given name, family name) Ken Reneris 



Inventor's Signature ^ ^^^^ 



Residence Wilbraham, Massachusetts USA Citizenship USA 

(City ^ State) {Country) 

P.O. Address 8 Red Gap Road 



Wilbraham, Massachusetts 01095 USA 



Full Name of Eighth/ Joint Inventor (given name, family name) 

Inventor's Signature 



Residence Portland, Oregon USA 



^ (City , ^tate) 

P. O. Address 20205 NW Paulina Drive 



Portland, Oregon 97229 USA 



James A. Sutton 



Date 



Citizenship USA 



(Country) 



Full Name of Ninth/ Joint Inventor (given name, family name) 
Inventor's Signature 



Residence Portland, Oregon USA 



(City , titate) 

P. O. Address 150 SW Moonridge Place 



Portland, Oregon 97225 USA 



Shreekant S. Thakkar 



Date 



Citizenship United Kingdom 

(Country) 



INTEL CORPORATION 

Rev. 09/09/99 (D3 INTEL) 



Docket No. 042390.P8097 



Full Name of Tenth/ Joint Inventor (given name, family name) Milland Mittal 



Inventor's Signature Date 



Residence Palo Alto, California USA Citizenship USA 



JCiiyTSiate) (Country) 

P, O, Address 800 East Charleston Road #29 

Palo Alto, California 94303 USA 



INTEL CORPORATION c i ^.....^n..^ 

Rev. 09/09/99 {D3 INTEL) ^ Docket No. 042390.P8097 



APPENDIX A 



I hereby appoint BLAKELY, SOKOLOFF, TAYLOR & ZAFMAN LLP, a firm including: William E. Alford, 
Reg. No. 37,764; Farzad E. Amini, Reg. No. 42,261; Amy M. Armstrong, Reg, No, 42,265; Aloysius T. C. AuYeung, 
Reg. No. 35,432; William Thomas Babbitt, Reg. No. 39,591; Carol F. Barry, Reg. No, 41,600; Jordan Michael Becker, 
Reg. No. 39,602; Bradley J. Bereznak, Reg. No. 33,474; Michael A. Bemadicou, Reg, No. 35,934; Roger W. Blakely, Jr., 
Reg. No. 25,831; Gregory D. Caldwell, Reg. No. 39,926; Ronald C. Card, Reg. No. 44,587; Thomas M. Coester, Reg. No. 
39,637; Donna Jo Coningsby, Reg. No. 41,684; Michael Anthony DeSanctis, Reg. No. 39,957; Daniel M, De Vos, Reg. 
No. 37,813; Robert Andrew Diehl, Reg. No. 40,992; Matthew C. Fagan, Reg. No. 37,542; Tarek N. Fahmi, Reg. No. 
41,402; George L. Fountain, Reg. No. 36,374; Paramita Ghosh, Reg. No. 42,806; James Y. Go, Reg. No. 40,621; James A. 
Henry, Reg. No. 41,064; Wilhnore F. Holbrow III, Reg. No. 41,845; Sheryl Sue HoUoway, Reg. No. 37,850; George W 
Hoover II, Reg. No. 32,992; Eric S. Hyman, Reg. No. 30,139; William W. Kidd, Reg. No. 31,772; Sang HuiKim, Reg, 
No. 40,450; Eric T. King, Reg, No, 44,188; Erica W. Kuo, Reg. No. 42,775; Michael J. Mallie, Reg, No. 36,591; Paul A, 
Mendonsa, Reg. No. 42,879; Darren J. Milliken, Reg. No. 42,004; Chun M. Ng, Reg. No. 36878; Thien T. Nguyen, Reg. 
No. 43,835; Thinh V. Nguyen, Reg. No. 42,034; Dennis A. Nicholls, Reg. No. 42,036; Lisa A. Norris, Reg, No, 44,976; 
Daniel E. Ovanezian, Reg. No. 41,236; William F. Ryann, Reg. No. 44,313; James H. Salter, Reg. No. 35,668; William W. 
Schaal, Reg. No. 39,018; James C. Scheller, Reg. No. 31,195; Jeffrey S. Smith, Reg. No. 39,377; Maria McCormack 
Sobrino, Reg. No. 31,639; Stanley W. Sokoloff, Reg. No. 25,128; Judith A. Szepesi, Reg, No. 39,393; Vincent P. 
Tassinari, Reg. No, 42,179; Edwin H. Taylor, Reg. No. 25,129; Joseph A. Twarowski, Reg. No. 42,191; Lester J. Vincent, 
Reg. No. 31,460; Glenn E. Von Tersch, Reg, No, 41,364; John Patrick Ward, Reg. No. 40,216; Charles T. J. Weigell, Reg. 
No. 43,398; James M. Wu, Reg. No. 45,241; Steven D, Yates, Reg. No. 42,242; and Norman Zafman, Reg. No. 26,250; 
my attorneys; and Andrew C. Chen, Reg. No. 43,544; Justin M. Dillon, Reg. No. 42,486; and John F. Travis, Reg. No. 
43,203; my patent agents, of BLAKELY, SOKOLOFF, TAYLOR & ZAFMAN LLP, with offices located at 12400 
Wilshhe Boulevard, 7th Floor, Los Angeles, California 90025, telephone (714) 557-3800, and Alan K. Aldous, Reg. No. 
31,905; Robert D. Anderson, Reg, No. 33,826; Joseph R. Bond, Reg. No. 36,458; Richard C. Calderwood, Reg. No. 
35,468; Jeffrey S. Draeger, Reg. No. 41,000; Cyn&ia Thomas Faatz, Reg No. 39,973; Sean Fitzgerald, Reg. No. 32,027; 
John N. Greaves, Reg. No. 40,362; Seth Z. Kalson, Reg. No. 40,670; David J. Kaplan, Reg. No, 41,105; Charles A. Mirho, 
Reg. No. 41,199; Leo V. Novakoski, Reg, No. 37,198; Naomi Obinata, Reg. No. 39,320; Thomas C. Reynolds, Reg. No. 
32,488; Kenneth M. Seddon, Reg. No. 43,105; Mark Seeley, Reg. No. 32,299; Steven P. Skabrat, Reg. No, 36,279; 
Howard A. Skaist, Reg. No. 36,008; Steven C. Stewart, Reg. No, 33,555; Raymond J. Werner, Reg. No. 34,752; Robert G. 
Winkle, Reg. No. 37,474; and Charles K. Young, Reg. No. 39,435; my patent attorneys, and Thomas Raleigh Lane, Reg. 
No. 42,781; Calvin E. Wells; Reg. No. P43,256, Peter Lam, Reg. No. 44,855; and Gene I. Su, Reg. No. 45,140; my patent 
agents, of INTEL CORPORATION; and James R. Thein, Reg. No. 31,710, my patent attorney; with full power of 
substitution and revocation, to prosecute this application and to transact all business in the Patent and Trademark Office 
connected herewith. 



6 



Docket No. 042390.P8097 



